import java.util.HashMap;

public class NumberOfSubarrays {

    public int numberOfSubarrays(int[] nums, int k) {
        int sum = 0;
        int ans = 0;
        HashMap<Integer, Integer> maps = new HashMap<>();
        for (int i = 0; i < nums.length; i++) {
            maps.put(sum, maps.getOrDefault(sum, 0) + 1);
            sum += nums[i] % 2 == 0 ? 0 : 1;
            ans += maps.getOrDefault(sum - k, 0);
        }
        return ans;
    }
}
